Amendments to the Claims 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 

Listing of Claims: 

1 . (currently amended) A method, usable in a computer system having host 
system memory, for increasing the data throughput performance of a memory controller, 
said memory controller being associated with controller memory, different from said host 
system memory, comprising: 

5 receiving data from a source; 

compressing said data; 

storing said data in said controller memor y, wherein said controller memory is 
one of SDRAM. DRAM, SRAM or RAM ; 
reading said data from said memory; 
10 decompressing said data; and 

providing said data to a data consumer. 

2. (original) The method of Claim 1, wherein said data is received from said 
source at a first data rate. 

3. (previously presented) The method of Claim 2, wherein said controller memory 
is capable of storing said data at a second data rate, wherein said first data rate is greater 
than said second data rate. 



2 



4. (currently amended) The method of Claim 3, wherein said data is provided to 
said d e stination data consumer at a third data rate, wherein said third data rate is greater 
than said second data rate. 

5. (original) The method of Claim 1, wherein said steps of compressing said data 
and decompressing said data are performed by an application specific integrated circuit 
(ASIC). 

6. (original) The method of Claim 1, wherein said steps of compressing said data 
and decompressing said data are performed by at least one of microcode and firmware 
running on a programmable microprocessor. 

7. (previously presented) The method of Claim 5, wherein said controller memory 
is external to said application specific integrated circuit. 

8. (previously presented) The method of Claim 5, wherein said controller memory 
is internal to said application specific integrated circuit. 

9. (previously presented) The method of Claim 1, further comprising 
decompressing said compressed data from said controller memory to a temporary buffer 
in response to receiving a request for random access to said compressed data. 
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10. (previously presented) The method of Claim 1, further comprising: 
receiving additional data; 

determining whether said additional data is capable of compression; and 
storing at least a portion of said additional data in said controller memory without 
5 first compressing said additional data if said data cannot be compressed. 

11. (original) The method of Claim 1, wherein said data source comprises at least 
one of a host system memory, a host processor, and a peripheral device. 

12. (previously presented) The method of Claim 1, wherein said data consumer 
comprises at least one of said host system memory, a host processor, and a peripheral 
device. 

13. (original) The method of Claim 1, wherein said data is received from said 
source by at least one of a first interface and a second interface, and wherein said data is 
provided to said data consumer by at least one of said first interface and said second 
interface. 

14. (original) The method of Claim 1, wherein said data is received from said 
source by a first interface, and wherein said data is provided to said data consumer by a 
second interface. 
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15. (currently amended) A method, usable in a computer system having host 
system memory, for increasing disk drive controller data throughput, said disk drive 
controller including controller memory, the method comprising: 

receiving uncompressed first data at a first interface; 
5 compressing said uncompressed first data to form compressed first data; 

writing said compressed first data to controller memory, said controller memory 
being different from said host system memor y, wherein said controller memory is one of 
SDRAM, DRAM, SRAM or RAM ; 

reading said compressed first data from said controller memory; 
10 uncompressing said compressed first data to recover said uncompressed first data; 

and 

providing said uncompressed first data to at least one of said first interface and a 
second interface. 

16. (previously presented) The method of Claim 15, wherein said first and second 
interfaces are capable of passing data at a first data rate, wherein said controller memory 
is capable of receiving data at a second data rate, and wherein said first data rate is 
greater than said second data rate. 

17. (previously presented) The method of Claim 15, wherein said first interface is 
interconnected to a host system bus, and wherein said step of receiving uncompressed 
first data at said first interface comprises receiving uncompressed data from a data source 
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comprising at least one of said host system memory, a host system processor 
5 interconnected to said host system bus, and a peripheral device. 

18. (original) The method of Claim 15, wherein said second interface comprises a 
channel of a storage device, and further comprising providing said uncompressed first 
data from said second interface to said storage device. 

19. (original) The method of Claim 18, wherein said storage device comprises at 
least one of a hard disk drive, a tape drive, an optical drive, and a three-dimensional 
storage device. 

20. (previously presented) The method of Claim 15, further comprising: 
receiving uncompressed second data at said second interface; 
compressing said uncompressed second data to form compressed second data; 
writing said compressed second data to said controller memory; 

5 reading said compressed second data from said controller memory; 

uncompressing said compressed second data to recover said uncompressed second 
data; and 

providing said uncompressed second data to at least one of said first interface and 
said second interface. 
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21. (previously presented) The method of Claim 15, wherein said step of 
compressing said uncompressed first data comprises compressing said uncompressed first 
data while said uncompressed first data is written to said controller memory. 

22. (previously presented) The method of Claim 20, wherein said step of 
compressing said uncompressed second data comprises compressing said uncompressed 
second data while said uncompressed second data is written to said controller memory. 

23. (previously presented) The method of Claim 15, further comprising: 
receiving uncompressed second data at a first interface; 

performing a compression routine with respect to at least a first portion of said 
second data, wherein said compression routine expands said second data; 
5 writing at least a second portion of said second data to said controller memory 

without performing said compression routine with respect to said at least said second 
portion of said second data. 

24. (original) The method of Claim 15, wherein said second portion of said 
second data comprises substantially all of said second data. 

25. (original) The method of Claim 15, wherein said second portion comprises all 
of said second data. 
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26. (original) The method of Claim 23, further comprising: 
reading said second data from said memory; 

decompressing said at least a second portion of said second data; and 
providing said second data to at least one of said first interface and said second 
interface. 

27. (currently amended) A memory controller having controller memory , usable 
in a computer system having host system memory, comprising: 

a first interface having a first data bandwidth; 

a second interface having a second data bandwidth; 

data compression circuitry; 

said controller memory having a third data bandwidth; and 
data decompression circuitry, wherein first data received at said first interface is 
compressed by said data compression circuitry for storage in said controller memory^ 
wherein said controller memory is one of SDRAM, DRAM, SRAM or RAM , and 
wherein said first data read from said controller memory is decompressed by said data 
decompression circuitry prior to being provided to at least one of said first interface and 
said second interface. 

28. (original) The memory controller of Claim 27, wherein said first data 
bandwidth plus said second data bandwidth is greater than said third data bandwidth. 
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29. (original) The memory controller of Claim 27, wherein said data compression 
circuitry and said data decompression circuitry has a fourth data bandwidth, and wherein 
said fourth data bandwidth is greater than said third data bandwidth. 

30. (original) The memory controller of Claim 27, wherein at least one of said 
data compression circuitry and said data decompression circuitry comprise an application 
specific integrated circuit. 

31. (previously amended) The memory controller of Claim 30, wherein said 
controller memory is external to said application specific integrated circuit. 

32. (previously amended) The memory controller of Claim 30, wherein said 
controller memory is internal to said application specific integrated circuit. 

33. (cancelled) 

34. (original) The memory controller of Claim 27, wherein said first interface is 
interconnected to a host computer. 

35. (original) The memory controller of Claim 27, wherein said second interface 
is interconnected to at least a first data storage device. 
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36. (original) The memory controller of Claim 35, wherein said at least a first data 
storage device comprises a hard disk drive. 

37. (original) The memory controller of Claim 27, wherein said memory 
controller is implemented within a controller of a data storage device. 

38. (original) The memory controller of Claim 37, wherein said data storage 
device comprises a hard disk drive. 

39. (previously presented) The memory controller of Claim 27, wherein at least a 
first portion of second data received at said first interface is expanded by said data 
compression circuitry, and wherein at least a second portion of said second data is stored 
in said controller memory in uncompressed form. 

40. (original) A method for providing a memory controller for a hard disk drive, 
comprising: 

receiving first data at one of a first interface and a second interface; 
compressing said first data; 
5 after said step of compressing said first data, writing said compressed first data to 

memory; 

reading said compressed first data from memory; 

after said step of reading said first data, decompressing said compressed data; 
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providing said uncompressed first data to at least one of said first interface and 
10 said second interface; 

receiving second data at one of said first interface and said second interface; 

compressing at least a first portion of said second data, wherein said step of 
compressing results in an expansion of said data; 

after said step of compressing at least a first portion of said second data, writing at 
15 least a second portion of said second data to said memory without compressing said at 
least a second portion of said second data; 

providing said at least a second portion of said second data to at least one of said 
first interface and said second interface. 

41. (original) The method of Claim 40, further comprising: 

setting a first compression flag to signal that said first data has been compressed. 

42. (original) The method of Claim 40, wherein said second interface comprises a 
channel of a peripheral device. 

43. (original) The method of Claim 40, further comprising: 
performing a CRC operation on said first data; 

providing at least one of a parity value and an error correction code to said at least 
one of said first interface and said second interface. 
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44. (New) The method of Claim 40 wherein said step of writing said compressed 
first data to memory comprises writing said compressed first data to one of SDRAM, 
DRAM, SRAM or RAM. 
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